package cn.csc.module.product.service.spudetail;

import cn.csc.framework.common.pojo.PageResult;
import cn.csc.module.product.controller.admin.spu.vo.SpuDataRespVO;
import cn.csc.module.product.controller.admin.spudetail.vo.SpuDetailCreateReqVO;
import cn.csc.module.product.controller.admin.spudetail.vo.SpuDetailExportReqVO;
import cn.csc.module.product.controller.admin.spudetail.vo.SpuDetailPageReqVO;
import cn.csc.module.product.controller.admin.spudetail.vo.SpuDetailUpdateReqVO;
import cn.csc.module.product.controller.app.spu.vo.AppSpuSearchPageReqVO;
import cn.csc.module.product.dal.dataobject.spudetail.SpuDetailDO;

import javax.validation.Valid;
import java.math.BigInteger;
import java.util.Collection;
import java.util.List;

/**
 * 商品详情信息 Service 接口
 *
 * @author liuchuang
 */
public interface SpuDetailService {

    /**
     * 创建商品详情信息
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    BigInteger createSpuDetail(@Valid SpuDetailCreateReqVO createReqVO);

    /**
     * 更新商品详情信息
     *
     * @param updateReqVO 更新信息
     */
    void updateSpuDetail(@Valid SpuDetailUpdateReqVO updateReqVO);

    /**
     * 删除商品详情信息
     *
     * @param id 编号
     */
    void deleteSpuDetail(BigInteger id);

    /**
     * 获得商品详情信息
     *
     * @param id 编号
     * @return 商品详情信息
     */
    SpuDetailDO getSpuDetail(BigInteger id);

    /**
     * 获得商品详情信息列表
     *
     * @param ids 编号
     * @return 商品详情信息列表
     */
    List<SpuDetailDO> getSpuDetailList(Collection<BigInteger> ids);

    /**
     * 获得商品详情信息分页
     *
     * @param pageReqVO 分页查询
     * @return 商品详情信息分页
     */
    PageResult<SpuDetailDO> getSpuDetailPage(SpuDetailPageReqVO pageReqVO);

    /**
     * 获得商品详情信息列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 商品详情信息列表
     */
    List<SpuDetailDO> getSpuDetailList(SpuDetailExportReqVO exportReqVO);

    /**
     * 获取访问商品最多次数的前10个商品
     * @return
     */
    List<SpuDetailDO> selectListDetailNum();


    /**
     * 商品点击次数统计加1
     * @param id
     */
    void detailNum(BigInteger id);


    /**
     * 获取访问量前十的spu
     * @return
     */
    List<SpuDataRespVO> getHot();

    /**
     * 按spuName模糊匹配
     * @param reqVO
     * @return
     */
    PageResult<SpuDataRespVO> searchLikeSpuName(AppSpuSearchPageReqVO reqVO);

}
